

# آزمایشگاه مدارمنطقی و معماری کامپیوتر مقدمه ای بر زبان برنامه نویسیVHDL و نرمافزار ISE

مهسا غلامی گروه مهندسی کامپیوتر،دانشکده فنی،دانشگاه گیلان

### Signal در VHDL

سیگنال یک کلمه کلیدی در کدنویسی VHDL میباشد.از سیگنال برای تعریف مقادیر میانی در پیادهسازی مدارات استفاده میشود.

```
library IEEE;
use IEEE.Std_Logic_1164.all;
entity DataTransm is
   port (Data: Std_Logic_Vector(15 downto 0));
end entity DataTransm;
architecture ExDecl of DataTransm is
signal Temp: Std_Logic;
signal FlagC, FlagZ: Bit;
begin
```



# VHDL در Variable

سیگنال یک کلمه کلیدی در کدنویسی VHDL میباشد اما متغیرها اطلاعات را در فرآیندها و زیربرنامه هایی که در آنها تعریف شده اند ذخیره میکنند.

;VARIABLE variable\_name : type\_name

#### تفاوت Signal با Variable؟

متغیرها برای ذخیره اطلاعات استفاده میشوند. (در پروسس ها و یا زیربرنامه ها) سیگنالها در واقع معادل "wire" است. (داخل یا خارج پروسس ها)

### **VHDL در** Component

کامپوننت یک ماژول در زبان VHDL میباشد. با استفاده از کامپوننت در واقع بجای یک کد پیچیده میتوان از یک حالت سلسله مراتبی استفاده کرد.

component Name is
port (input: in std\_logic;
output: out std\_logic);
end component;



#### **VHDL در Component**

نامهای ورودی و خروجی کامپوننت باید مشابه نامهای ورودی و خروجی انتیتی قطعه مورد نظر باشد.

مثلا یک نمونه از استفادهی کامپوننت در طراحی مالتی پلکسر 4:1 از چند مالتی پلکسر2:1 می توان نام برد.

#### CLK در VHDL

در مدارات ترتیبی از کلاکها استفاده میشود.

```
if clk'event and clk = '1' then
  int2 <= int2 + 1;
end if;</pre>
```

# هفتمین برنامه در VHDL



#### Truth Table

| J | K | CLK | Q                          |
|---|---|-----|----------------------------|
| 0 | 0 | †   | Q <sub>റ</sub> (no change) |
| 1 | 0 | t   | 1                          |
| 0 | 1 | t   | 0                          |
| 1 | 1 | †   | Q₀ (toggles)               |

## هشتمین برنامه در VHDL

| Rst | CLK | 03 | 02 | 01 | 00 |
|-----|-----|----|----|----|----|
| 1   | 1   | 0  | 0  | 0  | 0  |
| 0   | 1   | 0  | 0  | 0  | 1  |
| 0   | 1   | 0  | 0  | 1  | 0  |
| 0   | 1   | 0  | 0  | 1  | 1  |
| 0   | 1   | 0  | 1  | 0  | 0  |
| 0   | 1   | 0  | 1  | 0  | 1  |
| 0   | 1   | 0  | 1  | 1  | 0  |
| 0   | 1   | 0  | 1  | 1  | 1  |
| 0   | 1   | 1  | 0  | 0  | 0  |
| 0   | 1   | 1  | 0  | 0  | 1  |
| 0   | 1   | 1  | 0  | 1  | 0  |
| 0   | 1   | 1  | 0  | 1  | 1  |
| 0   | 1   | 1  | 1  | 0  | 0  |
| 0   | 1   | 1  | 1  | 0  | 1  |
| 0   | 1   | 1  | 1  | 1  | 0  |
| 0   | 1   | 1  | 1  | 1  | 1  |
| 0   | 1   | 0  | 0  | 0  | 0  |

شمارنده چهاربیتی اعداد با استفاده از پکیج :

use IEEE.STD\_LOGIC\_UNSIGNED.all;



پایان